vue | 您所在的位置:网站首页 › vue excel插件 › vue |
步骤一:安装插件 npm install xlsx file-saver -S npm install script-loader -S -D 步骤二:在src新建目录vendor 在vendor新建文件Export2Excel.js 然后将链接中的代码复制到Export2Excel.js https://github.com/PanJiaChen/vue-element-admin/edit/master/src/vendor/Export2Excel.js 注意:作者用的import 导入,在我的项目中打印XLSX一直是undefined,所以我用了下面的方式 import { saveAs } from 'file-saver' // import XLSX from 'xlsx' const XLSX = require('xlsx');步骤三:在vue中使用 methods: { exporfFile(){ import('@/vendor/Export2Excel').then(excel => { // 导出的表头名信息,也就是选中列 const tHeader = [ '序号', '企业名称', '区县', '管理类别', '行业类别', '申请类型', '开始时间', '结束时间', '时长', ] // 导出的表头字段名,需要导出表格字段名 const filterVal = [ 'index', 'devcompany', 'name_regiondetail', 'management', 'hyname', 'itemtype', 'start_time', 'end_time', 'time', ] //导出时如果需要序列,增加序列。 this.tableData1.forEach((item, index) => { item.index = index + 1 }) const list = this.tableData1 const data = this.formatJson(filterVal, list) excel.export_json_to_excel({ header: tHeader, //表头 必填 data, //具体数据 必填,字段名必须用data filename: 'excel-list', //非必填,自定义 autoWidth: true, //非必填 bookType: 'xlsx' //非必填 }) }) }, //处理数据格式将[{}……]处理为@/vendor/Export2Excel需要的[[]……]格式 formatJson(filterVal, jsonData) { return jsonData.map((v) => filterVal.map((j) => v[j])) }, }注意:数组的格式为数组套数组,且tHeader 元素的数量要和data中列的数量一致,且传递时注意,上面对象中橙色的属性data,一定要用'data'这个字段名,否则传递过去是undefined。 data的格式如下: [ [1, '标题一 'George',111] [2, '标题二', 'John', 2614,] [3, '标题三', 'Jennifer', 4787, ] ] |
CopyRight 2018-2019 实验室设备网 版权所有 |